<template>
  <div class="department-container">
    <div class="app-container">
      <el-card shadow="always" :body-style="{ padding: '20px' }">
        <!-- 具名插槽  hearder 指定卡片头部内容 -->
        <!-- <div slot="header"> -->
        <template #header>
          <el-row>
            <el-col :span="20">
              <!-- 左侧 : 部门名字 -->
              <span>{{ companyInfo.name }}</span>
            </el-col>
            <el-col :span="4">
              <!-- 右侧 -->
              <el-row type="flex" justify="end">
                <!-- 两个内容 -->
                <!-- 部门负责人 -->
                <el-col>负责人</el-col>
                <!-- 下拉菜单 element -->
                <el-col>
                  <el-dropdown>
                    <span> 操作<i class="el-icon-arrow-down" /> </span>
                    <el-dropdown-menu slot="dropdown">
                      <!-- 向公司下添加部门 =》 一级部门 -->
                      <el-dropdown-item @click.native="addDept()">
                        添加子部门
                      </el-dropdown-item>
                    </el-dropdown-menu>
                  </el-dropdown>
                </el-col>
              </el-row>
            </el-col>
          </el-row>
        </template>
        <!-- </div> => 默认插槽指定卡片内容 -->
        <div>
          <el-tree
            :data="treedata"
            :props="defaultProps"
            :default-expand-all="true"
            @node-click="handleNodeClick"
          >
            <!-- 1.自定义树的结构和样式
                   2.借助作用域插槽获取树节点数据
              -->
            <template #default="{ data }">
              <el-row style="width: 100%">
                <el-col :span="20">
                  <span>{{ data.name }}</span>
                </el-col>
                <el-col :span="4">
                  <el-row type="flex" justify="end">
                    <!-- 两个内容 -->
                    <el-col>{{ data.manager || "ceo" }}</el-col>
                    <el-col>
                      <!-- 下拉菜单 element -->
                      <el-dropdown>
                        <span> 操作<i class="el-icon-arrow-down" /> </span>
                        <!-- 下拉菜单 => 部门的操作按钮 -->
                        <el-dropdown-menu slot="dropdown">
                          <el-dropdown-item @click.native="addDept(data)">
                            添加子部门
                          </el-dropdown-item>
                          <el-dropdown-item @click.native="editDept(data)">
                            编辑部门
                          </el-dropdown-item>
                          <el-dropdown-item @click.native="delDepet(data)">
                            删除部门
                          </el-dropdown-item>
                        </el-dropdown-menu>
                      </el-dropdown>
                    </el-col>
                  </el-row>
                </el-col>
              </el-row>
            </template>
          </el-tree>
        </div>
      </el-card>
      <!-- 新增部门 -->
      <AddDept
        ref="edit"
        :show-dialog="showDialog"
        :current-node="currentNode"
        :all-tree-data="allTreeData"
        @close-dialog="showDialog = false"
        @update-tree="getAll"
      />
    </div>
  </div>
</template>
<script>
import { getDepartments, delDepartments } from '@/api/departments.js'
import { formatTreeData } from '@/utils/index.js'
import AddDept from './components/add-dept.vue'
export default {
  components: {
    AddDept
  },
  data () {
    return {
      // 控制弹层显示隐藏
      showDialog: false,
      // 公司信息
      companyInfo: { name: '' },
      // 公司组织架构的数据
      /**
       * 数据结构: 树形数据结构
       * [
       *  //顶级部门
       *  {
       *    name:"总裁办"
       *  },
       * {
       *    name:'研发部'
       *    children:[
       *         {
       *            name:'前端'
       *         },
       *         {
       *            name:'后端'
       *         }
       *      ]
       *    }
       * ]
       */
      treedata: [],
      // 自定义树形组件数据属性名
      defaultProps: {
        children: 'children',
        name: 'label'
      },
      // 所有部门数据
      allTreeData: [],
      // 当前点击的部门数据
      currentNode: null
    }
  },
  created () {
    this.getAll()
  },
  methods: {
    // 打开弹层
    addDept (node) {
      // 存储当前点击的部门数据 => 新增部门会使用
      this.currentNode = node
      this.showDialog = true
    },
    // 打开编辑部门弹层
    editDept (node) {
      this.currentNode = node
      this.showDialog = true
      // 回填当前编辑部门的数据 => 调用接口获取最新的部门数据
      // 打开的时候获取到当前编辑部门的ID => 调用接口
      // 父组件调用子组件的方法 => 使用ref ，绑定到子组件
      this.$refs.edit.getDept(node.id)
    },
    //  data 当前点击节点的数据
    handleNodeClick (data) {
      console.log(data)
    },
    // 获取所有部门数据
    async getAll () {
      const { companyName, depts } = await getDepartments()
      console.table(depts)
      // 存储公司信息
      // console.log(companyName)
      this.allTreeData = depts
      this.companyInfo.name = companyName
      // 存储部门列表数据 => 处理成树形结构
      // 深拷贝:JSON.parse(JSON.stringify(depts))
      // this.treedata = formatTreeData(JSON.parse(JSON.stringify(depts)))
      this.treedata = formatTreeData(depts)
      // this.treedata = depts
    },
    // 删除部门的方法
    delDepet (node) {
      console.log('当前操作的部门数据', node)
      /**
       * 步骤:
       * 1.判断是否是父级部门 =》 如果是的话 就不能删除
       * 2.子部门可以删除
       * 3.数据库删除:掉用接口
       * 4.提示并刷新列表
       */
      if (node.children && node.children.length > 0) {
        return this.$message({
          message: '不能删除父节点！',
          type: 'warning'
        })
      }
      // 提示用户是否确认删除
      this.$confirm(`确认删除${node.name}吗?`, '提示').then(async () => {
        // 点击确定
        await delDepartments(node.id)
        this.$message.success({
          message: '删除成功！'
        })
        this.getAll()
      }).catch(() => {
        this.$message.success({
          message: '取消成功'
        })
      })
    }
  }
}
</script>

<style lang="scss" scoped>
// scss 使用 ::v-deep 作为深度作用选择符 /deep/ == ::v-deep
::v-deep .el-tree-node_content {
  margin: 3px 0;
  font-size: 14px;
}
</style>
